<script setup lang="ts">
import { useRouter,useRoute } from 'vue-router';
import { mobileRules, passwordRules } from '@/utils/rules'
import { showFailToast,showSuccessToast } from "vant";
import { loginByPassword } from "@/services/user";
import { useUserStore } from "@/stores/user";
import { ref } from "vue";
const mobile = ref('13230000001')
const password = ref('abc12345')
const router = useRouter()
const route = useRoute()
const agree = ref(false)
const store = useUserStore()
const login = async () => { 
    
    // 检验通过后触发打印
    console.log('触发');
    // 先判断用户是否勾选用户协议
    if (!agree.value) return showFailToast('请勾选服务条款')
    // 发请求
     const res = await loginByPassword(mobile.value, password.value)
    // 存数据到🍍
    store.setUser(res.data)
    console.log(res.data);
    // 跳转页面  route.query.returnUr在封装响应拦截器的时候，在用户页面失效退出后再登录，返回之前退出来的页面，如果没有route.query.returnUr就返回主页，as断言因为我们自己封装是知道route.query.returnUrl是一个string
    router.push((route.query.returnUrl as string) || '/') //route.query是路由动态传参（id：或者其他，看文档）
    console.log(route.query);

    // 提示用户
    showSuccessToast('登录成功')
 }
</script>

<template>
  <div class="login-page">
    <cp-nav-bar
      right-text="注册"
      @click-right="router.push('/')"
    ></cp-nav-bar>
    <!-- 头部 -->
    <div class="login-head">
      <h3>密码登录</h3>
      <a href="javascript:;">
        <span>短信验证码登录</span>
        <van-icon name="arrow"></van-icon>
      </a>
    </div>
    <!-- 表单 -->
    <van-form autocomplete="off" @submit="login" >
      <van-field v-model="mobile" :rules="mobileRules" placeholder="请输入手机号" type="tel"></van-field>
      <van-field v-model="password" :rules="passwordRules" placeholder="请输入密码" type="password"></van-field>
      <div class="cp-cell">
        <van-checkbox v-model="agree">
          <span>我已同意</span>
          <a href="javascript:;">用户协议</a>
          <span>及</span>
          <a href="javascript:;">隐私条款</a>
        </van-checkbox>
      </div>
      <div class="cp-cell">
        <van-button block round type="primary" native-type="submit" >登 录</van-button>
      </div>
      <div class="cp-cell">
        <a href="javascript:;">忘记密码？</a>
      </div>
    </van-form>
    <!-- 底部 -->
    <div class="login-other">
      <van-divider>第三方登录</van-divider>
      <div class="icon">
        <img src="@/assets/qq.svg" alt="" />
      </div>
    </div>
  </div>
</template>

<style lang="scss" scoped>
.login {
  &-page {
    padding-top: 46px;
  }
  &-head {
    display: flex;
    padding: 30px 30px 50px;
    justify-content: space-between;
    align-items: flex-end;
    line-height: 1;
    h3 {
      font-weight: normal;
      font-size: 24px;
    }
    a {
      font-size: 15px;
    }
  }
  &-other {
    margin-top: 60px;
    padding: 0 30px;
    .icon {
      display: flex;
      justify-content: center;
      img {
        width: 36px;
        height: 36px;
        padding: 4px;
      }
    }
  }
}
.van-form {
  padding: 0 14px;
  .cp-cell {
    height: 52px;
    line-height: 24px;
    padding: 14px 16px;
    box-sizing: border-box;
    display: flex;
    align-items: center;
    .van-checkbox {
      a {
        color: var(--cp-primary);
        padding: 0 5px;
      }
    }
  }
  .btn-send {
    color: var(--cp-primary);
    &.active {
      color: rgba(22,194,163,0.5);
    }
  }
}
</style>
